# (11) EP 1 205 848 A1

# (12)

### **EUROPEAN PATENT APPLICATION**

(43) Date of publication: 15.05.2002 Bulletin 2002/20 (51) Int Cl.7: G06F 11/00

(21) Application number: 00124769.1

(22) Date of filing: 13.11.2000

(84) Designated Contracting States:
AT BE CH CY DE DK ES FI FR GB GR IE IT LI LU
MC NL PT SE TR
Designated Extension States:
AL LT LV MK RO SI

(72) Inventor: Plesner, Erik 7860 Spottrup (DK)

(71) Applicant: TELEFONAKTIEBOLAGET LM ERICSSON

(74) Representative: Roerboel, Lelf et al Budde, Schou & Ostenfeld A/S, Vester Soegade 10 1601 Copenhagen V (DK)

126 25 Stockholm (SE)

(54) Embedded microcontroller bound-out chip as preprocessor for a logic analyser

(57) The invention is concerned with providing access to all those internal signals of an embedded microcontroller that are necessary to debug software run on the microcontroller. In an embedded microcontroller, only some of these signals are directly accessible on the pins of the microcontroller. According to the invention,

the missing set of internal signals are provided with the enibedded microcontroller and connected in parallel herewith. The signals from the embedded microcontroller and from the bond-out chip are provided to a logic anatyser.



Fia. 4

Printed by Jouwe, 75001 PARIS (FR)

#### Description

#### TECHNICAL FIELD

[0001] The present invention relates to products comprising embedded microcontrollers (µC) and more particularly to debugging of the software while this is running real-time on a target embedded µC.

### BACKGROUND OF THE INVENTION

[0002] When designing products incorporating one or more embedded uC's, it is important to be able to debug the software executed by these µC's while such software is running real-time on the target µC's. This can in 15 general be achieved by using a modern logic analyser (LA) to perform inverse assembly (IA) of the code executed on the particular µC. By inverse assembly is meant a function which can be performed by modern logic analysers, provided the logic analyser has access to all signal activity on the address bus, the data bus, the bus control signals and the microprocessor status signals. The logic analyser also is provided with a copy of the software executed by the microprocessor and of the symbol table. By combining these data, the logic analvser can visualise how the software was executed and carry out source code correlation in the same manner as an Interactive debugger. The process is, however, not interactive, i.e. the program flow can only be inspected, not altered.

[0003] In most cases where embedded µC's are not used, the inverse assembly carried out by the logic analyser works on the control- and status signals of the microprocessor (µP) core. This is a straightforward approach in the case of a general purpose µP (e.g. for use in workstations), where the µP has all status and control signals from the core directly accessible on the pins of the µP chip.

10004) On a μC designed for the embodded market, the μP ore and most of the control signeds are concerned on-chip and only visible through an external bus interface (EBI). Only a sub-set of the address- and data signals are accessible off-chip, and all of the μP control and status signals are used to generate a tew off-chip control signals in the nave the wrong format with respect to the inverse assembly or do not provide enough status information from the core of the μP to allow the inverse assembly to work correct. The profession is particularly serious if the EBI contains data or program eache (or both). The native control and status signals are concealed on-chip in order to save pins on the package of the embedded μC, thereby saving both area and costs.

[0005] The manufactures of embedded µC's are addressing this problem by offering so called "bond-out" versions of the chips, which may have many more pins in order to allow all internal busses and control- and status signals to be routed to an external pin. The bond to

chip behaves exactly like the embedded  $\mu C$  chip and makes the internal signals observable by the LA/IA at the same time.

[0008] Bond-out chips are often used in emulators.

5 Emulators usually contain a number of auxiliary logicarcuits, buffers, housekeeping microprocessors, memory,
host interfaces etc. The buffers and other auxiliary logic
circuits imply that the emulator can not run at the full
speed of the embedded µC chip. Emulators are generul
ally expensives, sophisticated pieces of equipment that
often require a lot of configuration in order to work correct with the target application. The major drawback of
an emulator is, however, that the µC chip on the target
has to be removed and replaced by the emulator pod.

15 This is a serious problem with fine pitch SND µC's.

#### SUMMARY OF THE INVENTION

[0007] According to the preceding description of the problems of debugging software while this is running real-time on a target embedded microcontroller, it is an object of the present invention to provide a device with the aid of which all internal signals relevant for said debugging of software can be made observable.

25 [0008] It is a further object of the present invention to provide a device which can be used as a pre-processor for a logic analyser in that it generates the missing internal signals from the microcontroller which are needed to carry out said debugging with the aid of the logic analyser.

[0009] As a consequence of the disadvantages associated with the use of an emulator to simulate the behaviour of the microprocessor core in the embedded microcontroller, it is a further object of the present invention to provide full observability to the internal signals of the microprocessor core without using an emulator.

[0010] According to the invention, these objects are attained by using a bond-out chip to generate said miss-Ing internal signals. According to the Invention, the bond-out chip is connected in parallel to all pins of the target embedded microcontroller. In this manner the bond-out chip receives exactly the same input signals as the target embedded microcontroller and hence behaves in exactly the same way. Thus, the bond-out chip can for instance be used as a pre-processor for a logic analyser providing those internal signals from the embedded microcontroller which are not directly accessible/observable from outside. In this way the logic analyser is not looking at the target microprocessor itself, but at a 100% correct mirror hereof. The subset of signals from the target embedded microcontroller that are accessible from outside are thus provided to the logic analyser, and an exact replica of those signals not present from outside the target microcontroller is provided by the bond-out chip.

[0011] In this manner the disadvantages of using an emulator in the debugging process as set forth in the introduction are overcome. It is specifically advanta-

geous that the target microcontroller need not to be removed during debugging (in fact the target microcontroller must necessarily be present in order to deliver said subset of signals that are accessible from the target microcontroller). Furthermore, a pre-processor according to the invention is much less complex than a usual emulator and hence much cheaper, and no set-up of the pre-processor is required as opposed to the emulator. [012] It is a further major advantage with the preprocessor according to the invention that it is the target

processor according to the invention that it is the target microcontroller itself that is controlling the target circuit board and not an emulator or the pre-processor.

[0013] It is a further advantage with the pre-processor

according to the invention that although there will be a speed penalty due to the time constant resulting from parasitic capacitance's and protection resistors which will necessarily be present in a practical embodiment of the invention, the pre-processor will nevertheless in general be able to run at a higher speed than the emulator.

[0014] Furthermore, it is an advantage that the preprocessor according to the invention can - and normally will - be powered from the target microcontroller. In cases where an emulator is used instead of the pre-processor according to the invention, both target and emu- 25 lator must be turned off (i.e. not powered) when the emulator is connected and disconnected to/from the target. During the power-up phase, it is very important to power up the target and the emulator in the right sequence. Specifically the emulator should always be powered up before the target or vice versa. The right sequence depends on the emulator. If the target and the emulator are powered up in the wrong sequence, permanent damage may occur to the target or the emulator or both. This problem is entirely eliminated with the pre-processor according to the invention.

## BRIEF DESCRIPTION OF THE DRAWINGS

[0015] The Invention will now be described in more 40 detail with reference to the accompanying drawings, in which

figure 1 is a microprocessor  $\mu P$  with observable signals connected to a logic analyser;

figure 2 is an embedded microcontroller  $\mu C$  with concealed signals;

figure 3 is a bond-out chip connected to a logic analyser; and

figure 4 is an embedded μC connected to a bondout chip functioning as a pre-processor for a logic analyser according to the present invention.

# DETAILED DESCRIPTION OF THE INVENTION

[0016] In the following a detailed description of one embodiment of the Invention is given. Specifically this embodiment is shown in figure 4, whereas figures 1 through 3 are related to prior art, as already briefly described in the introduction.

[0017] With reference to figure 1, there is shown a miroprocessor. If D designated by 1 nunning software to be of edugged. The microprocessor 1 is provided with access terminals for status, address, data: and control signals respectively, and all of these signals are accessible for a logic analyser 6 via appropriate signal paths 2, 3, 4 and 5. All signals from the microprocessor 1 are thus observable from outside, and it is thus ossable us-

2, 3, 4 and 5. All signals from the microprocessor 1 are f thus observable from outside, and it is thus possible using the logic analyser 6 to trace the execution of the software completely. [0018] An entirely different situation is depicted in fig-

uuts] An entreny amerent situation is depicted in ligure 2 showing an embedded microcontroller, LC 7 comprising a microprocessor core 8 running the software to be debugged. In this case some of the signals needed for a logic analyser to trace the software execution are made observable via an external bus interface EBI 13 provided in the embedded microcontroller, but only a 5 sub-set of the address- and data signals 10, 11 are observable off-chip, and all of the control- and status signals 12, 9 from the microprocessor are used to generate a few off-chip control signals, or simply ignored. The logic analyser 6 thus suffers from a lack of informalion neo-

croprocessor core 8.
[0019] A prior at solution to this problem is presented in figure 3 where the microprocessor core 14 of the embedded microcontroller? is a bond-out chip thus providing external access/observability to all relevant signals in the microprocessor core 14. The bond-out chip comprises prins making the status signals of the microprocessor core in directly observable, as indicated by 2 in the flugure and similarly prins providing observability to continuous control since it is a control to the flugure and similarly prins providing observability to control since its 3. data salnals 4 and address sincels.

essary to be able to trace software execution in the mi-

the microprocessor core 14.

[0020] Thus, the logic analyser 6 is in this case provided with all necessary information to be able to perform inverse assembly.

5 [0021] Referring now to figure 4, there is shown a bond-out toly functioning as a pre-processor for a logic analyser according to the present invention. The figure shows the bond-out ohip 15 connected in parallel with the target embedded microcontroller 7. Specifically the 9 I/O ports of the target and the pre-processor are connected via but 16, and the external bus inferences (EBI) 13 of the pre-processor 15 and the target 7 respectively are interconnected by means of busses 17, 18 and 19 carrying address-, data- and control signals respective-5 y. Internal status-, control-, data- and address signals are furthermore provided by the bond-out chip 15 to the logic analyser 5 via busses 2, 3, 4 and 5 respectively. The pre-processor 15 is connected to all plins of the tar-

30

get microcontroller 7 for instance by means of a Snap-On probe clip attached to the target microcontroller or via dedicated board-to-board connectors surrounding the target microcontroller. The logic analyser is provided with signals from the target microcontroller 7 and with 5 additional control- and status signals from the bond-out chip 15. It is advantageous - although not always necessary - that the RESET signals of the embedded microcontroller 7 and of the bond-out chip 15 be synchronised to the system clock signal in order to guarantee 10 that the target chip and the bond-out chip recognises desertion of reset in the same clock cycle. When the microcontroller is configuring itself after reset, this is done In exactly the same way on both the target microcontroller 7 and the pre-processor 15 Including the functionality 15 and polarity of I/O pins. If this feature is not present, the pre-processor 15 will normally function anyway, but this can not generally be guaranteed.

[0022] On the pre-processor 15, those signals which are input-only on the target microcontroller 7 are connected directly to the bond-out chip. Signals which are bi-directional - or which can be programmed to be either input or output on the target microcontroller 7 - are connected to target through suitable protection resistors (not shown), e.g. 330 ohms resistors. In this way they 25 still work as inputs bot will not be able to cause contention when they are working as outputs. This is important. as the target chip and the bond-out chip may have different timing due to different batches, temperature, ageing etc.

[0023] The value of the protection resistors must be chosen large enough to ensure that the maximum output current of the respective microcontroller pin (Imax) can not be exceeded. Specifically it is required that R>= Vcc/imax, where Vcc is the supply voltage.

[0024] Furthermore, if the target microcontroller contains non-volatile memory, it must be assumed that the non-volatile memories of the target microcontroller 7 and the pre-processor bond-out chip 15 are identical before the pre-processor 15 is connected to the target microcontroller 7. If the non-volatile memory of the target microprocessor 7 can be in-circuit programmed, the target microcontroller 7 can be programmed with the preprocessor 15 fitted. The programming will affect the preprocessor 15 as well, and the problem is solved (subject 45 to programming algorithm).

[0025] In the embodiment shown in figure 4, the bondout chip 15 receives its power supply 20 directly from the power supply Vcc of the embedded microcontroller 7, as previously mentioned.

#### Claims

 A method for debugging software run on an embed- 55 ded microcontroller (7), a first subset of the internal signals of which are accessible from outside and the remaining internal signals of which are not accessible from outside, said method comprising:

Establishing the necessary external connections to/from the embedded microcontroller (7) to enable this to execute the software run by the microcontroller in a desired manner;

Connecting a second microcontroller (15), a second subset of the internal signals of which are accessible from outside, in parallel with said embedded microcontroller (7):

> Providing said first subset of internal signals from the embedded microcontroller (7) that are accessible from outside and which are necessary for said debugging to a logic analyser (6):

> Providing the remaining internal signals which are required for software debugging from said second microcontroller (15) to said logic analyser (6);

where said second microcontroller (15) is functionally identical with said embedded microcontroller (7).

- 2. A method according to claim 1, where the RESET signals of the embedded microcontroller (7) and of said second microcontroller (15) are synchronised with the aid of the system CLOCK signal.
- 3. A method according to claim 1, where said second subset of internal signals comprise all internal signals from the second microcontroller (15).
- 4. A method according to claim 1, where said second subset of internal signals comprise control-, data-, address- and status signals (4, 5, 6, 9) from said microcontrollers (7, 15).
- 5. A system for debugging software run on an embedded microcontroller (7), some of the internal signals of which are accessible from outside and some of which are not accessible from outside, said system comprising:

A bond-out chip (15) functionally identical to said embedded microcontroller (7), where all internal signals (2, 3, 4, 5) are accessible from

A logic analyser (6) receiving all internal signals necessary for said debugging:

Where said bond-out chip (15) is connected in parallel with said embedded microcontroller (7), and where a first subset of internal signals necessary for said debugging is provided to said logic analyser (6) from said microcontroller (7), and the remaining internal signals necessary for said debugging is provided to said logic analyser (6) from said bondout chip (15).

- 6. A system according to claim 5, where those signals that are only input signals to said embedded microcontroller are connected to the corresponding input terminals on said bond-out chip directly, whereas those signals which are bi-firectional, or which can robe programmed to be either input or output signals tofrom said embedded microcontroller (7) are connected to the microcontroller (7) through protection resistors.
- 7. A system according to claim 6, where said protection resistors are chosen according to the equation R>= Vcc/lmax, where Vcc is the supply voltage and lmax is the maximum allowable current for the specific terminal of the microcontroller.
- A system according to claim 6, where said protection resistors are in the order of 330 ohms.
- A system according to any of the preceding claims 5 to 8, where said bond-out chip (15) receives its power supply (20) directly from the power supply of said embedded microcontroller (7).
- 10. A device for providing observability of all Internal signals from an embedded microcontroller (7), said device comprising a bond-out chip (15) functionally identical with said embedded microcontroller (7).

40

45

50

55



Fig. 1



Fig. 2



Fig. 3



Fig. 4



EP 00 12 4769

| Category                                                  | Citation of document with a<br>of relevant pass                                                                                                                                                              | ndication, where appropriate.<br>seges                                                                                                      | Relevant<br>to daim                            | CLASSIFICATION OF THE<br>APPLICATION (Int.C1.7) |
|-----------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------|-------------------------------------------------|
| X                                                         | US 6 016 563 A (FLEISHER EVGENY 6) 18 January 2000 (2000-01-18) * column 2, line 61 - column 3, line 2; figure 2 * * column 7, line 2-5 *                                                                    |                                                                                                                                             | 1-10                                           | G05F11/00                                       |
| ١                                                         | US 6 085 342 A (GAE<br>AL) 4 July 2000 (20<br>* column 7, line 50                                                                                                                                            |                                                                                                                                             | 2                                              |                                                 |
|                                                           | DEBUGGING MIT DER B<br>ELEKTRONIK, DE, FRANZ<br>MUNCHEN,<br>vol. 44, no. 4,<br>21 February 1995 (1<br>98-102, XP000502975<br>ISSN: 0013-5658                                                                 | 995-02-21), pages<br>d column, line 37 ~                                                                                                    | 1-10                                           |                                                 |
| - 1                                                       | MELEAR C: "M88000 DEVELOPMENT TOOLS"                                                                                                                                                                         |                                                                                                                                             | 1-10                                           | TECHNICAL FIELDS<br>SEARCHED (InLCI.7)          |
|                                                           | WESCON TECHNICAL PAPERS, US, WESTERN PERIODICALS CO. MORTH HOLLYMOOD, vol. 32, 1 November 1988 (1988-11-01), pages 1-4, XP000048782 * page 2, right-hand column, line 25 page 3, left-hand column, line 39 * |                                                                                                                                             |                                                | G06F                                            |
|                                                           | The present search report has                                                                                                                                                                                | oeen drawn up for all etairins                                                                                                              |                                                |                                                 |
|                                                           | Place of search                                                                                                                                                                                              | Dete of completion of the search.                                                                                                           | ــــــــــــــــــــــــــــــــــــــ         | Example                                         |
|                                                           | THE HAGUE                                                                                                                                                                                                    | 10 April 2001                                                                                                                               | Huy                                            | ghe, E                                          |
| X : partir<br>Y : partir<br>decu<br>A : techi<br>O : non- | ATEGORY OF CITED DOCUMENTS<br>cutarly relevant if taxen alone<br>cutarly relevant if combined with anot<br>interest of the same category<br>notogical background<br>-written disclosure<br>mediate document  | T : theory or princip E : carrier patient de effer the Hilling de their D : document cited L : document of the t document of the t document | ite<br>In the application<br>for other reasons |                                                 |

#### EP 1 205 848 A1

#### ANNEX TO THE EUROPEAN SEARCH REPORT ON EUROPEAN PATENT APPLICATION NO.

. . . .

EP 00 12 4769

This annox lists the patent family members relating to the patent documents cited in the above-mentioned European search report. The members are as contained in the European Patent Office EDP file on The European Patent Office is fin on varylable for those particulars which are merely given for the purpose of information.

10-04-2001

| Patent document<br>cited in search report | Publication date | Patent family<br>member(s)                                                   | Publication<br>date                                      |
|-------------------------------------------|------------------|------------------------------------------------------------------------------|----------------------------------------------------------|
| US 6016563 A                              | 18-01-2000       | NONE                                                                         |                                                          |
| US 6085342 A                              | 04-07-2000       | AU 7460598 A<br>BR 9809213 A<br>CN 1261965 T<br>EP 0980549 A<br>WO 9850859 A | 27-11-19<br>27-06-20<br>02-08-20<br>23-02-20<br>12-11-19 |
|                                           |                  |                                                                              |                                                          |
|                                           |                  |                                                                              |                                                          |
|                                           |                  |                                                                              |                                                          |
|                                           |                  |                                                                              |                                                          |
|                                           |                  |                                                                              |                                                          |
|                                           |                  |                                                                              |                                                          |
|                                           |                  |                                                                              |                                                          |
|                                           |                  |                                                                              |                                                          |
|                                           |                  |                                                                              |                                                          |
|                                           |                  |                                                                              |                                                          |
|                                           |                  |                                                                              |                                                          |
|                                           |                  |                                                                              |                                                          |

For more details about this annex ; see Official Journal of the European Patent Office, No. 12/82